Oracle更改字段类型Blob错误ora

您所在的位置:网站首页 oracle blob字段修改 Oracle更改字段类型Blob错误ora

Oracle更改字段类型Blob错误ora

2023-08-11 21:17| 来源: 网络整理| 查看: 265

    近日工作中发现有一张表的字段类型建错了,本应是BLOB类型却被别人建成了VARCHAR2(200),修改时oracle却提示“ORA-22858 invalid alteration of datatype”错误。经查看相关资料才了解,是oracle不允某些类型的字段修改。具体就是不可以将字段类型修改为:object、REF、nested table、VARRAY、 CLOB、BLOB。解决方案也很简单就是像学数据结构时经常用到的两变量(a,b)交换值的方法,c = a, a = b, b = c。当然我们这里可以简单处理,具体方法如下:1、将字段a改名为_a2、新建一个字段a,用正确的类型3、将_a字段中的数据经一定转换(一般要做转换的,因为类型变了)后插入了a字段中4、删除_a字段如果无需保留数据只要1、2、3步就可以了。如果表中或该字段中还没有数据,那就更简单了,把那个字段删除再以正确的数据类型新建一个即可。

正面是本错误的官方解释:

ORA-22858 invalid alteration of datatype

Cause: An attempt was made to modify the column type to object, REF, nested table, VARRAY or LOB type.

Action: Create a new column of the desired type and copy the current column data to the new type using the appropriate type constructor.



【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3